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(54) Title: SYSTEM AND METHOD FOR PROVIDING INFORMATION TO APPLETS IN A VIRTUAL MACHINE 

(57) Abstract 

A system (110) and method for simultaneously dis- 
playing a set of display applets (figure 3) while optimizing 
the number of server connections (150). A connection to 
the server (150) is established by a controlling applet. The 
controlling applet receives data from the server, parses the 
data, transmits the data to a set of display applets, and dis- 
plays the set of display applets on a single browser window 
(fig.5). Even if an applet is torn off a single browser win- 
dow and moved to another window, the controlling applet 
continually maintains a link to the server (150) to continu- 
ally update the data values on the torn off applet as well as 
on the set of display applets on the single browser window 
(fig.5). 
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SYSTEM AND METHOD FOR PROVIDING INFORMATION 
5 TO APPLETS IN A VIRTUAL MACHINE 

CROSS-REFERENCE TO RELATED APPLICATIONS 
This application claims priority from provisional 
10 patent application 60/040,876, filed March 21, 1997. 



BACKGROUND OF THE INVENTION 
The present invention relates to applets in a 
virtual machine and more particularly to the display of 

15 multiple applets on a single browser window while optimizing 
the number of server connections. 

The Internet is a global network that allows users 
to communicate information. To access this information, a 
user executes a client program, usually a Web browser such as 

20 Hot Java, Netscape, or Microsoft Explorer, which connects the 
user to the Internet. The Web browser issues specific 
commands to the Internet which accesses a particular Web 
server. A Web server is a computer system that provides 
information to the client through the Internet link. 

25 Once a connection to the Internet has been 

established, the user can then retrieve a multitude of Web 
sites. A Web site is a series of screen displays (Web pages) 
consisting of text, pictorial, and other information about a 
particular subject, organization, or company. Web pages can 

30 be created using HyperText Markup Language ("HTML"). A 

particular Web site can be retrieved from the Internet by 
specifying its Web site address to the Web browser. 

Java is an increasingly well-known and popular 
object-oriented programming language which was developed by 

35 Sun Microsystems in 1995. Java's architecture allows machine- 
independent executable instructions to be distributed over a 
network onto a Java enabled Web browser. Unlike many other 
programming languages, Java is interpreted and is designed to 
be highly machine independent and can run under many browser 
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clients. This includes Sun workstations, Pes, Macs, PDAs, and 
even television sets. In one implementation, a Java 
interpreter runs within a client's processor space and can 
execute the Java interpreted instructions on the client within 
5 the Web browser. 

Java supports all of the productivity enhancing 
features of object-oriented programming. For example, Java 
enables programmers to use existing classes to create new 
classes. This is called inheritance. A class is a category 

10 of objects. By defining a new class, a programmer specifies 
the shape and behavior of all objects later defined to be 
instances of that class, including the data they will contain 
and the operations they will perform. 

During the development of Java, the developers 

15 realized that code downloaded from a network may be less 
secure than code that resides on a local hard drive. 
Therefore, one of the desirable features of Java is the fact 
that Java executable instructions have only limited access to 
computer system resources, such as the file system. Among 

20 other things, this provides some protection from viruses or 
from maliciously designed code or erroneous code from 
corrupting system resources. 

Java utilizes applets as a security mechanism to 
prevent any linked viruses from attaching to the client's hard 

25 drive. An applet is a small program with a single purpose 
designed to be distributed across a network, usually the 
Internet, often to add extra functionality to some other 
program, such as a Web browser. In Java, a user can specify 
exactly which directories applets can read from and write to. 

30 An applet is not executed directly by the processor, 

but rather by an implementation of a Java virtual machine 
(VM) . The Java VM is another name for the Java interpreter. 
The Java interpreter is built into many popular Web browsers 
such as Netscape and Hot Java. The Java VM produces no machine 

35 instructions specific to a particular processor but rather 
single compiled versions of the program, called bytecodes . 
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These bytecodes are downloaded onto the Web browser in the 
form of an applet, and the VM interprets and runs the program 
code . 

An application differs from an applet in that an 
5 application is a stand alone program, usually executable code, 
that resides on a processor* If an application contains a 
virus and the application is downloaded from the Internet onto 
the processor, the processor may become infected. Hence, an 
applet provides a more secure medium for data transmission as 

10 compared to an application. 

In an operating system environment, multiple 
programs having multiple applets can be run simultaneously. 
Each of these programs has at least one thread within it. A 
thread is a parallel path of execution which runs 

15 independently. Problems arise when multiple threads attempt 

to connect to a server simultaneously. For example, suppose a 
user wishes to display or update multiple applets on a single 
Web page. This requires that each applet establish its own 
connection to the server. If more than one applet requests 

20 data from the server at the same time, one applet may be 

competing with another applet for a server connection. Hence, 
each applet may be waiting to initiate a server connection 
resulting in inefficiencies. Furthermore, a first applet may 
be accessing data file A and waiting for data file B and a 

25 second applet may be accessing data file B and waiting for 
data file A resulting in deadlock. 

Ideally, what is needed is a mechanism for allowing 
a group of applets to . communicate with a server efficiently. 

3 0 SUMMARY OF THE INVENTION 

The present invention provides systems and methods 
for simultaneously displaying a set of applets while 
optimizing the number of server connections. 

In one embodiment, the invention provides a method 
35 of providing data to a set of display applets, comprising the 
steps of: establishing a connection from a client to a server 
by a controlling applet; transmitting data from the server to 
the controlling applet; sending the data by the controlling 
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applet to a set of display applets; and updating and 

displaying the set of display applets. 

Additionally, one of the set of applets may be "torn 

off 11 a single browser window on a Web page and moved to 
5 another window on the same Web page. The "torn off" display 

applet will be continually updated by the controlling applet. 

Even if multiple display applets are "torn off" the single 

browser window, the controlling applet will continue to 

maintain a connection to the server and will continue to 
10 update each "torn off" display applet with new data. 

Advantages of the invention include providing the 

display and updating of multiple display applets on a single 

Web browser window while maintaining only one connection to 

the server. Additionally, the invention allows the capability 
15 of tearing off a display applet from the single browser window 

and moving the display applet to another window while 

continually updating all the display applets. 

A further understanding of the nature and advantages 

of the inventions herein may be realized by reference to the 
20 remaining portions of the specification and the attached 

drawings . 



BRIEF DESCRIPTION OF THE DRAWINGS 
Fig, 1 illustrates some examples of multiple 
25 hardware systems networked over the Internet which are used to 
execute the software of an embodiment of the present 
invention; 

Fig. 2 illustrates a high level flowchart of a 
method of providing data to a set of display applets by a 
3 0 controlling applet; 

Fig. 3 illustrates the hierarchy of inheritance of 
one embodiment of the present invention; 

Fig. 4 illustrates a system block diagram of a 
typical computer system used to execute the software of an 
35 embodiment of the present invention; and 

Fig. 5 illustrates a display of one embodiment of 
the invention which depicts the display of six display applets 
on a single browser window. 
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DETAILED DESCRIPTION OF SPECIFIC EMBODIMENTS 
In the description that follows, the present 
invention will be described in reference to a preferred 
5 embodiment that operates on the Internet. In particular, 
examples will be described which illustrate particular 
applications of the invention on the Internet. The present 
invention, however, is not limited to any particular 
information source nor limited by the examples described 

10 herein. Therefore, the description of the embodiments that 
follow are for purposes of illustration and not limitation. 

Fig. 1 illustrates some examples of multiple 
hardware systems networked over the Internet which are used to 
execute the software of an embodiment of the present 

15 invention. A computer system 110, a television set 120, or a 
terminal 130 are some examples of hardware devices used to 
access the Internet 140, For convenience, the term "client" 
will be used to refer to the computer system 110, television 
set 120, or terminal 130. Generally to retrieve information 

20 through the Internet 140, a client program, such as Netscape 
or Microsoft Explorer, is run on the client to connect the 
client to a particular Web server 150. 

Fig. 2 illustrates a high level flowchart of a 
method of providing data to a set of display applets by a 

25 controlling applet. At step 310, a client applet is created 
above an applet class where the client applet inherits 
functions from the applet class. The client applet is an 
abstract class which provides a higher level of inter-applet 
communication. Inter-applet communication occurs when a 

30 controlling applet interfaces and communicates with a set of 
display applets. The set of display applets and the 
controlling applet are all client applets. 

Typically, the controlling applet is a hidden 
applet. This means that its height and width parameters are 

35 zero. The height and width parameters are used to define 

screen space for the display of an applet. For example, in 
one embodiment as shown in Fig. 5, six display applets are 
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displayed on a single browser window each display applet 
having a height parameter of 220 and a width parameter of 200. 

The controlling applet is an active applet which 
means that it has established a connection to the server. The 
5 set of display applets are passive applets which means that 

they do not establish a connection to the server. Even though 
the passive applets do not have a connection to the server, 
their information is continually updated by the controlling 
applet . 

10 At step 312, the set of display applets are 

initialized by the Java VM. At this time, the controlling 
applet waits for the Java VM to complete the initialization of 
all the display applets. After initialization, the 
controlling applet establishes a connection to the server for 

15 data transfer at step 314. Typically, a connection to the 

server is established within a thread. A thread is a parallel 
path of execution which runs independently. 

At step 316, the controlling applet utilizes a 
thread to send a data request from the client to the server 

20 requesting new data. At step 318, the server responds by 

sending data which can be any structured data understood by 
the controlling applet. Typically, the data is a keyword, the 
data values, and an end of line indicator. For example, the 
new data is sent in the following format: pktdist 117.3 8 77.78 

25 12.98 58.78 6.24 86.84 <EOL> . Thus, the keyword is "pktdist n 
corresponding to packet distribution. 

At step 320, the data is parsed by the controlling 
applet. This involves the controlling applet breaking up the 
data into individual parts and processing each part 

30 separately. For example, the controlling applet filters out 
the "pktdist" label to determine which display applet to send 
the new data to. 

At step 322, the controlling applet reads an ID 
string from each display applet. The ID string is used to 

35 inform the controlling applet which display applet is to 

receive the new data. For example, one display applet might 
provide the controlling applet a "pktdist" ID string. Once 
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the controlling applet receives the ID string, it compares the 
ID 

string to the keyword at step 324. When the controlling 
applet finds a match between the ID string and the keyword, 
5 the controlling applet send the data to the appropriate 
display applet at step 326. 

At step 328, the display applet that received the 
new data is updated. This generally requires a repainting or 
redisplaying operation. The display applets are generally 

10 displayed on a single browser window on a Web page. 

At step 330, the controlling applet sends a request 
to the server for new data. If there is new data, steps 318 
through 328 are repeated. If there is no new data, the 
controlling applet waits, typically for 3 0 seconds, and makes 

15 another request to the server for new data. Once all the 
display applets are closed, the thread that maintains the 
connection between the controlling applet and the server is 
terminated. 

Although steps 310 through 33 0 are shown in a 
20 particular order, it is not required that these steps be 

performed in the order shown. Thus, the order shown in the 
flowchart is to illustrate one embodiment and not to limit the 
invention. 

Fig. 3 illustrates the hierarchy of inheritance of 
25 one embodiment of the present invention. The client applet 
inherits functions from the applet class. Pie Chart, Bar 
Chart, Line Graph, and Controlling Applet are all client 
applets. Furthermore, all the display applets are client 
applets and inherit functions from the applet class. Packet 
30 distribution, packet rates, top 10 errors, top 10 host, 

network statistics, and network throughput are all display 
applets which inherit functions from the client applet. 
Inter-applet communication occurs when the controlling applet 
communicates with the set of display applets. 
35 Fig. 4 illustrates a system block diagram of a 

typical computer system 110 used to execute the software of an 
embodiment of the present invention. As shown in Fig. 4, 
computer system 110 includes speaker 240, monitor 250, and 
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keyboard 270. Computer system 110 further includes subsystems 
such as I/O controller 210, system memory 220, central 
processor 230, removable disk 260 (e.g., CD-ROM drive), fixed 
disk 280 (e.g., hard drive), and network interface 290. Other 
5 computer systems suitable for use with the present invention 
may include additional or fewer subsystems. 

Arrows such as 2 05 represent the systems bus 
architecture of computer system 110. These arrows illustrate 
the interconnection scheme used to link together the 

10 subsystems. For example, a local bus could be utilized to 
connect the central processor 230 to the keyboard 270. 
Computer system 110 shown in Fig. l is one example of a system 
suitable for use with the present invention. As shown in Fig. 
1, a television set 120 and a terminal 130 are other examples 

15 of systems suitable for use with the present invention. Also, 
other configurations of subsystems suitable for use with the 
present invention will be readily apparent to one of ordinary 
skill in the art. 

Fig. 5 illustrates a display of one embodiment of 

20 the invention which depicts the display of six display applets 
on a single browser window. As mentioned above, each display 
applet has a height parameter of 220 and a width parameter of 
200. The controlling applet has a height and width parameter 
of zero. 

25 By clicking on the "Window" icon at the upper left 

corner of each display applet, the user can move the 
particular display applet to another window. For example, if 
the user clicks on the "Window" icon corresponding to Packet 
Size Distribution, the "torn off" applet window will move to 

30 the upper top left corner of the user's display screen. Even 
though the "torn off" applet window is at another screen 
location, the "torn off" applet is still continuously being 
updated by the controlling applet. Furthermore, even if 
multiple applets are "torn off" the single browser window, the 

35 controlling applet will continue to maintain a connection to 
the server and will continue to update each "torn off" applet 
with new data. This results in continually updating multiple 
display applets while maintaining only one server connection. 
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The invention has now 
to specific embodiments. Other 
to one of ordinary skill in the 
intended that this invention be 
by the appended claims. 



been explained with reference 
embodiments will be apparent 
art . It is therefore not 
limited, except as indicated 
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1 1, A method of providing data to a plurality of 

2 display applets comprising the steps of: 

3 establishing a connection from a client to a server 

4 by a controlling applet; 

5 transmitting data from said server to said 

6 controlling applet; 

7 sending said data by said controlling applet to a 

8 plurality of display applets; and 

9 updating and displaying said plurality of display 
applets . 

1 2. The method as recited in claim 1 further 

2 comprising the step of reading an identification string from 
said plurality of display applets by said controlling applet. 

1 3. The method as recited in claim 1 wherein said 

2 data comprises a keyword, a numerical value, and an end of 
data indicator. 

1 4. The method as recited in claim 2 wherein said 

2 data comprises a keyword and further comprising the step of 

3 comparing said identification string to said keyword by said 
controlling applet. 

1 5. A method of providing data to a plurality of 

2 display applets comprising the steps of : 

3 creating a client applet above an applet class for 

4 inter-applet communication with a plurality of display 

5 applets; 

6 initializing said plurality of display applets; 

7 establishing a connection from a client to a server 

8 by a controlling applet; 

9 sending a data request from said client to said 

10 server by said controlling applet; 

11 reading an identification string from each one of 

12 said plurality of display applets by said controlling applet; 
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13 transmitting a keyword and data from said server to 

14 said controlling applet; 

15 parsing said data in the controlling applet; 

16 comparing said identification string to said keyword 

17 by said controlling applet; 

18 sending said data by said controlling applet to said 

19 plurality of display applets based on the results from said 

20 step of comparing said identification string to said keyword; 

21 and 

22 updating and displaying said plurality of display 
applets . 

1 6. The method as recited in claim 5 wherein said 

2 step of updating and displaying said plurality of display 
applets is performed on a single browser window on a Web page . 

1 7. The method as recited in claim 6 further 

2 comprising the step of moving one of said plurality of display 
applets to another window. 

1 8. The method as recited in claim 5 wherein said 

2 plurality of display applets are updated with said data by 
said controlling applet. 

1 9. The method as recited in claim 5 wherein said 

2 controlling applet sends said data to said plurality of 
display applets . 

1 10. The method as recited in claim 5 wherein said 

connection is performed in a thread. 

1 11. The method as recited in claim 5 wherein said 

2 controlling applet inherits a set of functions from said 



applet class. 



1 
2 



12 . The method as recited in claim 5 wherein said 
data comprises of any structured data understood by said 
controlling applet. 
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1 13. The method as recited in claim 5 wherein said 

2 step of displaying said plurality of display applets comprises 

3 displaying six display applets on said single browser window 
on said Web page. 

1 14 . The method as recited in claim 5 wherein said 

2 step of sending a data request from said client to said server 

3 by said controlling applet is repeated after a selected period 
of time. 

1 15 . A computer program product for providing 

2 data to a plurality of display applets, said product 

3 comprising: 

4 code that creates a client applet above an applet 

5 class for inter-applet communication with a plurality of 

6 display applets; 

7 code that establishes a connection from a client to 

8 a server by a controlling applet; 

9 code that reads an identification string from each 

10 one of said plurality of display applets by said controlling 

11 applet; 

12 code that transmits a keyword and data from said 

13 server to said controlling applet; 

14 code that compares said identification string to 

15 said keyword; 

16 code that sends said data by said controlling applet 

17 to said plurality of display applets; and 

a computer-readable medium for storing said codes. 

1 16 . The computer program product as recited in 

2 claim 15 further comprising code that parses said data in said 
controlling applet. 

1 17. The computer program product as recited in 

2 claim 15 further comprising code that updates and displays 
said plurality of display applets. 
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.18. The computer program product as recited in 
claim 15 further comprising code that initializes said 
plurality of display applets. 



19. The computer program product as recited in 
claim 15 further comprising code that sends a data request 
from said client to said server by said controlling applet. 
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